博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
django 链接地址匹配流程
阅读量:4637 次
发布时间:2019-06-09

本文共 1485 字,大约阅读时间需要 4 分钟。

前提:

 

代码结构

 

 

步骤一:

下面为某个网页的链接地址

{% if latest_article_list %}    
{% else %}

No articles are available.

{% endif %}

其中的链接地址为:

步骤二: 点击链接后,进行URL匹配。 第一层 mysite中的url.py
urlpatterns = [    url(r'^admin/', include(admin.site.urls)),    url(r'^blog/',include('blog.urls'))]

第二层 blog中的url.py

urlpatterns = [    url(r'^$', views.index, name='index'),    url(r'^p/(?P
[0-9]+)/$', views.detail,name='detail')]

 

步骤三:

然后调用view.detail  (在view.py中)

def detail(request, article_id):    article = get_object_or_404(Article, pk=article_id)    return render(request, 'blog/p/detail.html', {
'article': article})

 

步骤四:

然后返回 目录 blog/p/detail.html

    
ARTICLE

{
{ article.title }}

{

{ article.content }}

根据article.id值在数据库中查找相应字段,填充article.title和article.content的具体值。

效果:

 

需要注意的是地址栏为:

而不是detail.html的目录

 

移除硬编码

 

html文件中的链接   {
{ article.title }}
blog中的url.py文件有name参数
urlpatterns = [    url(r'^$', views.index, name='index'),    url(r'^p/(?P
[0-9]+)/$', views.detail,name='detail')]
所以使用{% url %}标签,链接改为
{
{ article.title }}
处理多个项目出现相同的detail,使用命名空间

在mysite的url中设置

urlpatterns = [     url(r'^admin/', include(admin.site.urls)),     url(r'^blog/',include('blog.urls', namespace='blog')) ]
链接改为
{
{ article.title }}

 

转载于:https://www.cnblogs.com/hb91/p/5410660.html

你可能感兴趣的文章
【编程题目】数组中超过出现次数超过一半的数字 ☆
查看>>
php 加密解密类
查看>>
10 款简单精美的 jQuery 和 CSS3 表单
查看>>
云计算开发一般负责什么工作呢?云计算是做什么的?
查看>>
[转]Windows Shell 编程 第十二章【来源:http://blog.csdn.net/wangqiulin123456/article/details/7987999】...
查看>>
ubuntu常用技巧积累
查看>>
Java入门第二季——Java中的this关键字
查看>>
MYSQL指令
查看>>
《大道至简》读后感
查看>>
如何优化电量
查看>>
测试用例编写(功能测试框架)
查看>>
问题解决 Visual Studio 2015 无法复制文件“D:\swapfile.sys”
查看>>
eclipse 关联 Maven本地仓库的配置
查看>>
注册表收藏夹路径
查看>>
移动端自动化测试环境搭建
查看>>
【小前端】float属性
查看>>
[Unity插件]Lua行为树(十):通用行为和通用条件节点
查看>>
类StringBuilder
查看>>
212. Word Search II
查看>>
218. The Skyline Problem
查看>>